.\" Copyright (c) 2020-2022 by Alejandro Colomar <alx@kernel.org>
.\" and Copyright (c) 2020 by Michael Kerrisk <mtk.manpages@gmail.com>
.\"
.\" SPDX-License-Identifier: Linux-man-pages-copyleft
.\"
.\"
.TH time_t 3type 2022-10-30 "Linux man-pages 6.03"
.SH NAME
time_t, suseconds_t, useconds_t \- integer time
.SH LIBRARY
Standard C library
.RI ( libc )
.SH SYNOPSIS
.nf
.B #include <time.h>
.PP
.BR typedef " /* ... */  " time_t;
.PP
.B #include <sys/types.h>
.PP
.BR typedef " /* ... */  " suseconds_t;
.BR typedef " /* ... */  " useconds_t;
.fi
.SH DESCRIPTION
.TP
.I time_t
Used for time in seconds.
According to POSIX,
it is an integer type.
.\" In POSIX.1-2001, the type was specified as being either an integer
.\" type or a real-floating type. However, existing implementations
.\" used an integer type, and POSIX.1-2008 tightened the specification
.\" to reflect this.
.TP
.I suseconds_t
Used for time in microseconds.
It is a signed integer type
capable of storing values al least in the range
.RB [ \-1 ,
.BR 1000000 ].
.TP
.I useconds_t
Used for time in microseconds.
It is an unsigned integer type
capable of storing values al least in the range
.RB [ 0 ,
.BR 1000000 ].
.SH VERSIONS
.TP
.I time_t
.I <sched.h>
defines
.I time_t
since POSIX.1-2008.
.TP
.I suseconds_t
POSIX.1-2001 defined
.I useconds_t
in
.I <unistd.h>
too.
.SH STANDARDS
.PD 0
.IR time_t :
C99 and later;
POSIX.1-2001 and later.
.PP
.IR suseconds_t ,
.IR useconds_t :
POSIX.1-2001 and later.
.PD
.SH NOTES
On some architectures,
the width of
.I time_t
can be controlled with the feature test macro
.BR _TIME_BITS .
.TP
.I time_t
The following headers also provide
.IR time_t :
.IR <sched.h> ,
.IR <sys/msg.h> ,
.IR <sys/select.h> ,
.IR <sys/sem.h> ,
.IR <sys/shm.h> ,
.IR <sys/stat.h> ,
.IR <sys/time.h> ,
.IR <sys/types.h> ,
and
.IR <utime.h> .
.TP
.I suseconds_t
The following headers also provide
.IR suseconds_t :
.I <sys/select.h>
and
.IR <sys/time.h> .
.SH SEE ALSO
.BR stime (2),
.BR time (2),
.BR ctime (3),
.BR difftime (3),
.BR usleep (3),
.BR timeval (3type)
